{% extends '_base_list.html' %}
{% load i18n static %}
{% block table_search %}
    <div class="" style="float: right">
       <div class=" btn-group">
            <button data-toggle="dropdown" class="btn btn-default btn-sm dropdown-toggle">CSV <span class="caret"></span></button>
            <ul class="dropdown-menu">
                <li>
                    <a class=" btn_export" tabindex="0">
                    <span>{% trans "Export" %}</span>
                    </a>
                </li>
                <li>
                    <a class=" btn_import" data-toggle="modal" data-target="#import_modal" tabindex="0">
                    <span>{% trans "Import" %}</span>
                    </a>
                </li>
                <li>
                    <a class=" btn_update" data-toggle="modal" data-target="#update_modal" tabindex="0">
                    <span>{% trans "Update" %}</span>
                    </a>
                </li>
            </ul>
       </div>
   </div>
{% endblock %}
{% block table_container %}
<div class="pull-left m-r-5"><a href="{% url 'users:user-group-create' %}" class="btn btn-sm btn-primary ">{% trans "Create user group" %}</a></div>
<table class="table table-striped table-bordered table-hover " id="group_list_table" >
    <thead>
        <tr>
            <th class="text-center">
                <input id="" type="checkbox" class="ipt_check_all">
            </th>
            <th class="text-center">{% trans 'Name' %}</th>
            <th class="text-center">{% trans 'User' %}</th>
            <th class="text-center">{% trans 'Comment' %}</th>
            <th class="text-center">{% trans 'Action' %}</th>
        </tr>
    </thead>
</table>
{% include "users/_user_groups_import_modal.html" %}
{% include "users/_user_groups_update_modal.html" %}
{% endblock %}

{% block content_bottom_left %}{% endblock %}
{% block custom_foot_js %}
<script>
var groups_table = 0;
function initTable() {
    var options = {
        ele: $('#group_list_table'),
        buttons: [],
        columnDefs: [
            {targets: 1, createdCell: function (td, cellData, rowData) {
                cellData = htmlEscape(cellData);
                var detail_btn = '<a href="{% url "users:user-group-detail" pk=DEFAULT_PK %}">' + cellData + '</a>';
                $(td).html(detail_btn.replace('{{ DEFAULT_PK }}', rowData.id));
             }},
            {targets: 2, createdCell: function (td, cellData, rowData) {
                var html = createPopover(cellData);
                $(td).html(html);
             }},
            {targets: 3, createdCell: function (td, cellData) {
                cellData = htmlEscape(cellData);
                var innerHtml = cellData.length > 30 ? cellData.substring(0, 30) + '...': cellData;
                $(td).html('<span href="javascript:void(0);" data-toggle="tooltip" title="' + cellData + '">' + innerHtml + '</span>');
             }},
            {targets: 4, createdCell: function (td, cellData, rowData) {
                var name = htmlEscape(rowData.name);
                var update_btn = '<a href="{% url "users:user-group-update" pk=DEFAULT_PK %}" class="btn btn-xs btn-info">{% trans "Update" %}</a>'
                        .replace('{{ DEFAULT_PK }}', cellData);
                var del_btn = '<a class="btn btn-xs btn-danger m-l-xs btn_delete_user_group" data-gid="{{ DEFAULT_PK }}" data-name="99991938">{% trans "Delete" %}</a>'
                        .replace('{{ DEFAULT_PK }}', cellData)
                        .replace('99991938', name);
                if (rowData.id === 1) {
                    $(td).html(update_btn)
                } else {
                    $(td).html(update_btn + del_btn)
                }
            }}
        ],
        ajax_url: '{% url "api-users:user-group-list" %}?display=1',
        columns: [{data: function(){return ""}}, {data: "name" }, {data: "users", orderable: false},
                  {data: "comment"}, {data: "id", orderable: false, width:"100px"}],
        order: [],
        op_html: $('#actions').html()
    };
    groups_table = jumpserver.initServerSideDataTable(options);
    return groups_table
}
$(document).ready(function() {
    initTable()

}).on('click', '.btn_delete_user_group', function(){
    var $this = $(this);
    var group_id = $this.data('gid');
    var name = $this.data('name');
    var the_url = "{% url 'api-users:user-group-detail' pk=DEFAULT_PK %}".replace('{{ DEFAULT_PK }}', group_id);
    objectDelete($this, name, the_url)
}).on('click', '#btn_bulk_update', function(){
    var action = $('#slct_bulk_update').val();
    var $data_table = $('#group_list_table').DataTable()
    var plain_id_list = [];
    $data_table.rows({selected: true}).every(function(){
        plain_id_list.push(this.data().id);
    });
    if (plain_id_list === []) {
        return false;
    }
    var the_url = "{% url 'api-users:user-group-list' %}";
    function doDelete() {
        swal({
            title: "{% trans 'Are you sure?' %}",
            text: "{% trans 'This will delete the selected groups !!!' %}",
            type: "warning",
            showCancelButton: true,
            cancelButtonText: "{% trans 'Cancel' %}",
            confirmButtonColor: "#DD6B55",
            confirmButtonText: "{% trans 'Confirm' %}",
            closeOnConfirm: false
        }, function() {
            var success = function() {
                var msg = "{% trans 'UserGroups Deleted.' %}";
                swal("{% trans 'UserGroups Delete' %}", msg, "success");
                $data_table.ajax.reload();
            };
            var fail = function() {
                var msg = "{% trans 'UserGroup Deleting failed.' %}";
                swal("{% trans 'UserGroups Delete' %}", msg, "error");
            };
            var url_delete = the_url + '?id__in=' + JSON.stringify(plain_id_list);
            requestApi({url: url_delete, method: 'DELETE', success: success, error: fail});
            jumpserver.checked = false;
        });
    }
    switch(action) {
        case 'delete':
            doDelete();
            break;
        default:
            break;
    }
}).on('click', '.btn_export', function(){
    var groups = groups_table.selected;
    var data = {
        'resources': groups
    };
    var search = $("input[type='search']").val();
    var props = {
        method: "POST",
        body: JSON.stringify(data),
        success_url: "{% url 'api-users:user-group-list' %}",
        format: "csv",
        params: {
            search: search
        }
    };
    APIExportData(props);
}).on('click', '#btn_import_confirm',function () {
        var url = "{% url 'api-users:user-group-list' %}";
        var file = document.getElementById('id_file').files[0];
        if(!file){
            toastr.error("{% trans "Please select file" %}");
            return
        }
        var data_table = $('#group_list_table').DataTable();
        APIImportData({
            url: url,
            method: "POST",
            body: file,
            data_table: data_table
        });
})
.on('click', '#download_update_template', function(){
    var groups = groups_table.selected;
    var data = {
        'resources': groups
    };
    var search = $("input[type='search']").val();
    var props = {
        method: "POST",
        body: JSON.stringify(data),
        success_url: "{% url 'api-users:user-group-list' %}?format=csv&template=update",
        format: "csv",
        params: {
            search: search
        }
    };
    APIExportData(props);
}).on('click', '#btn_update_confirm',function () {
        var url = "{% url 'api-users:user-group-list' %}";
        var file = document.getElementById('update_file').files[0];
        if(!file){
            toastr.error("{% trans "Please select file" %}");
            return
        }
        var data_table = $('#group_list_table').DataTable();
        APIImportData({
            url: url,
            method: "PUT",
            body: file,
            data_table: data_table
        });
})

</script>
{% endblock %}
